![@thi.ng/geom-clip-line](https://media.thi.ng/umbrella/banners-20230807/thing-geom-clip-line.svg?bda30e3e)
![Mastodon Follow](https://img.shields.io/mastodon/follow/109331703950160316?domain=https%3A%2F%2Fmastodon.thi.ng&style=social)
[!NOTE]
This is one of 201 standalone projects, maintained as part
of the @thi.ng/umbrella monorepo
and anti-framework.
🚀 Please help me to work full-time on these projects by sponsoring me on
GitHub. Thank you! ❤️
About
2D line clipping (Liang-Barsky). This is a support package for @thi.ng/geom.
Current implementation is partially based on toxiclibs
(Java) and Clojure version thi.ng/geom-clj. Also see
@thi.ng/geom-clip-poly
sister package.
The following main functions are provided:
Status
STABLE - used in production
Search or submit any issues for this package
Related packages
Installation
yarn add @thi.ng/geom-clip-line
ESM import:
import * as gcl from "@thi.ng/geom-clip-line";
Browser ESM import:
<script type="module" src="https://esm.run/@thi.ng/geom-clip-line"></script>
JSDelivr documentation
For Node.js REPL:
const gcl = await import("@thi.ng/geom-clip-line");
Package sizes (brotli'd, pre-treeshake): ESM: 762 bytes
Dependencies
Note: @thi.ng/api is in most cases a type-only import (not used at runtime)
API
Generated API docs
import { clipPolylinePoly, liangBarsky2 } from "@thi.ng/geom-clip-line";
clipPolylinePoly(
[[10, -50], [30, 30], [-50, 50], [150, 50], [70, 70], [90, 150]],
[[0, 0], [100, 0], [100, 100], [0, 100]]
);
liangBarsky2(
[-10, -20], [30, 400],
[0, 0], [100, 200]
)
liangBarsky2(
[-10, -20], [-30, 400],
[0, 0], [100, 200]
)
Authors
If this project contributes to an academic publication, please cite it as:
@misc{thing-geom-clip-line,
title = "@thi.ng/geom-clip-line",
author = "Karsten Schmidt",
note = "https://thi.ng/geom-clip-line",
year = 2013
}
License
© 2013 - 2025 Karsten Schmidt // Apache License 2.0